<!-- eslint-disable vue/prop-name-casing -->
<script lang="ts" setup>
import Edit from './edit.vue';

import {
  getTenantAccountList,
  //  userAccountDelete
} from '@/api/consumer';
import { usePaging } from '@/hooks/usePaging';
// import feedback from '@/utils/feedback'
import { useComponentRef } from '@/utils/getExposeType';

const props = defineProps({
  tenant_id: {
    type: Number,
    default: 0,
  },
});

const showEdit = ref<boolean>(false);
const editRef = useComponentRef(Edit);

const queryParams = reactive({
  keyword: '',
  create_time_start: '',
  create_time_end: '',
  tenant_id: props.tenant_id,
});

const { pager, getLists, resetPage, resetParams } = usePaging({
  fetchFun: getTenantAccountList,
  params: queryParams,
});
onActivated(() => {
  getLists();
});

const handleShow = async (type: 'add' | 'edit', id?: number) => {
  showEdit.value = true;
  await nextTick();
  editRef.value?.open(type, id);
};

// const handleDelete = async (id: number) => {
//     await feedback.confirm('确定要删除？')
//     await userAccountDelete({ id })
//     getLists()
// }

onMounted(() => {
  getLists();
});
</script>

<template>
  <div class="flex h-full flex-col">
    <el-form class="-mb-4 flex flex-wrap gap-x-4" :model="queryParams" :inline="true">
      <el-form-item label="账号信息" class="!mr-0 min-w-[200px] max-w-[300px] flex-1">
        <el-input
          v-model="queryParams.keyword"
          placeholder="账号/名称"
          clearable
          @keyup.enter="resetPage"
        />
      </el-form-item>
      <el-form-item label="创建时间" class="!mr-0 min-w-[350px] max-w-full flex-1">
        <daterange-picker
          v-model:start-time="queryParams.create_time_start"
          v-model:end-time="queryParams.create_time_end"
        />
      </el-form-item>
      <el-form-item class="!mr-0">
        <el-button type="primary" @click="resetPage">查询</el-button>
        <el-button @click="resetParams">重置</el-button>
        <!-- <el-button @click="handleShow('add')">新增</el-button> -->
        <export-data
          class="ml-2.5"
          :fetch-fun="getTenantAccountList"
          :params="queryParams"
          :page-size="pager.size"
        />
      </el-form-item>
    </el-form>
    <el-table class="mt-4 flex-1" v-loading="pager.loading" :data="pager.lists" height="100%">
      <el-table-column label="头像" width="90" align="center">
        <template #default="{ row }">
          <el-avatar :src="row.avatar" :size="50" />
        </template>
      </el-table-column>
      <el-table-column label="名称" prop="name" min-width="100" />
      <el-table-column label="账号" prop="account" min-width="100" />
      <el-table-column label="状态" min-width="80">
        <template #default="{ row }">
          <el-tag :type="row.disable === 0 ? 'primary' : 'danger'">
            {{ row.disable === 0 ? '开启' : '关闭' }}
          </el-tag>
        </template>
      </el-table-column>
      <el-table-column label="创建时间" prop="create_time" min-width="120" />
      <el-table-column label="操作" width="auto" min-width="90" fixed="right">
        <template #default="{ row }">
          <el-button
            v-perms="['user.user/edit']"
            class="mr-1"
            type="primary"
            link
            @click="handleShow('edit', row.id)"
          >
            编辑
          </el-button>
          <!-- <el-button
                        v-perms="['user.user/delete']"
                        class="!ml-0"
                        type="danger"
                        link
                        @click="handleDelete(row.id)"
                    >
                        删除
                    </el-button> -->
        </template>
      </el-table-column>
    </el-table>
    <div class="mt-4 flex justify-end">
      <pagination v-model="pager" @change="getLists" />
    </div>
    <Edit
      v-if="showEdit"
      ref="editRef"
      :tenant_id="props.tenant_id"
      @refresh="getLists"
      @close="showEdit = false"
    />
  </div>
</template>
